<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>文章列表</title>
    <link rel="stylesheet" href="./libs/bootstrap/css/bootstrap.min.css">
    <link rel="stylesheet" href="./css/reset.css">
    <link rel="stylesheet" href="./css/iconfont.css">
    <link rel="stylesheet" href="./css/main.css">
    <script src="./libs/jquery-1.12.4.min.js"></script>
    <!-- 引入模板引擎js文件 -->
    <script src="./libs/template-web.js"></script>
    <!-- 引入分页导航插件 -->
    <script src="./libs/jquery.twbsPagination.js"></script>
</head>

<body>
    <div class="container-fluid">
        <div class="common_title">
            文章列表
        </div>
        <div class="container-fluid common_con">
            <div class="row opt_btns">
                <div class="col-xs-6">
                    <form class="form-inline">
                        <select id="selCategory" name="" class="form-control input-sm">
                            <option value="">所有分类</option>
                            <option>未分类</option>
                            <option>奇趣事</option>
                            <option>会生活</option>
                            <option>爱旅行</option>
                        </select>
                        <select id="selStatus" name="" class="form-control input-sm">
                            <option value="">所有状态</option>
                            <option value="草稿">草稿</option>
                            <option value="已发布">已发布</option>
                        </select>
                        <button id="btnSearch" class="btn btn-default btn-sm">筛选</button>
                    </form>
                </div>
                <div class="col-xs-6">
                    <a href="article_release.html" class="btn btn-success btn-sm pull-right" id="release_btn">发表文章</a>
                </div>
            </div>
            <table class="table table-striped table-bordered table-hover mp20">
                <thead>
                    <tr>
                        <th>标题</th>
                        <th>作者</th>
                        <th>分类</th>
                        <th class="text-center">发表时间</th>
                        <th class="text-center">状态</th>
                        <th class="text-center" width="100">操作</th>
                    </tr>
                </thead>
                <tbody>
                    <tr>
                        <td>王积千造统最头</td>
                        <td>杰克</td>
                        <td>奇趣事</td>
                        <td class="text-center">2017-06-08 07:08:46</td>
                        <td class="text-center">已发布</td>
                        <td class="text-center">
                            <a href="article_edit.htmlss" class="btn btn-default btn-xs">编辑</a>
                            <a href="javascript:void(0);" class="btn btn-danger btn-xs delete">删除</a>
                        </td>
                    </tr>
                </tbody>
            </table>
            <div class="row text-center">
                <ul id="pagination" class="pagination-sm"></ul>
            </div>
        </div>
    </div>
</body>

</html>
<!-- 准备文章类别模板引擎 -->
<script type="text/html" id="tpl-category">
    <option value="">所有状态</option>
    {{each data}}
    <option value="{{$value.id}}">{{$value.name}}</option>
    {{/each}}
</script>


<!-- 准备文章列表模板引擎 -->
<script type="text/html" id="tpl-list">
{{each data.data}}
<tr>
    <td>{{$value.title}}</td>
    <td>{{$value.author}}</td>
    <td>{{$value.category}}</td>
    <td class="text-center">{{$value.date}}</td>
    <td class="text-center">{{$value.state}}</td>
    <td class="text-center">
        <a href="article_edit.html?articleId={{$value.id}}" class="btn btn-default btn-xs" data-id="{{$value.id}}">编辑</a>
        <a href="javascript:void(0);" class="btn btn-danger btn-xs delete" data-id="{{$value.id}}">删除</a>
    </td>
</tr>
{{/each}}


</script>
<script src="./libs/https.js"></script>
<script>
    $(function () {

        // 发起ajax请求 获取文章类别下拉框数据
        $.ajax(
            {
                type: 'get',
                url: BigNew.category_list,
                success: function (backData) {
                    if (backData.code == 200) {
                        let htmlStr = template('tpl-category', backData)
                        $('#selCategory').html(htmlStr)
                    }
                }
            }
        )

        // 封装一个函数  获得文章数据列表  渲染结构
        // 传入 形参 page代表的是当前选中的页码


        // 定义一个全局变量  记录当前页数 
        let selpage = 1
        function loadData(page) {
            selpage = page
            $.ajax(
                {
                    type: 'get',
                    url: BigNew.article_query,
                    data: {
                        // 首次加载的时候 类与状态都是空
                        type: $('#selCategory').val(),
                        state: $('#selStatus').val(),
                        // page 请求指定页码的数据 
                        page: page,
                        // perpage 每页显示多少条数据 
                        perpage: 5,
                    },
                    success: function (backData) {
                        if (backData.code == 200) {
                            // console.log(backData);

                            // 判断返回的数据有没有内容
                            // 如果有内容  渲染结构
                            if (backData.data.totalCount > 0) {
                                let htmlStr = template('tpl-list', backData)
                                $('tbody').html(htmlStr)
                                // 准备分页导航
                                // 所有的分页导航属性 都是第一次设置时才有效
                                // 解决办法：在设置分页导航之前 先摧毁之前的导航
                                $('#pagination').twbsPagination('destroy');
                                $('#pagination').twbsPagination(
                                    {
                                        // 总页数
                                        totalPages: backData.data.totalPage,
                                        // 最大可见页数
                                        visiblePages: 6,
                                        // 当前被选中的页数
                                        startPage: page,
                                        prev: '上一页',
                                        next: '下一页',
                                        last: '尾页',
                                        first: '首页',
                                        // 默认的点击事件  设置false表示不要默认的点击事件
                                        initiateStartPageClick: false,
                                        // 页码的点击事件
                                        onPageClick: function (event, page) {
                                            // console.log(page);
                                            // 根据点击的页码  获得指定的文章数据 重新加载页面
                                            // page 代表是当前点击的页面
                                            loadData(page)
                                        }
                                    }
                                );
                            } else {
                                // 如果没有内容 把tbody的内容清空 
                                // $('tbody').html('')
                                $('tbody').empty()
                                $('#pagination').html('当前类别没有任何数据......')

                            }
                        }
                    }
                }
            )
        }
        loadData(1)

        // 给筛选按钮添加点击事件
        $('#btnSearch').on('click', function (e) {
            // 阻止默认行为
            e.preventDefault()
            // 根据选中的类型以及状态，请求指定的数据，然后渲染页面 
            // 每次请求会不同的数据 都应该从第一页开始
            loadData(1)
        })
        // 给每个删除按钮添加点击事件   用委托
        $('tbody').on('click', '.delete', function () {
            let delid = $(this).attr('data-id')
            // console.log(delid);
            // 发起ajax请求  删除文章信息
            $.ajax(
                {
                    type: 'post',
                    url: BigNew.article_delete,
                    data: {
                        id: delid
                    },
                    success: function (backData) {
                        if (backData.code == 204) {
                            // loadData(selpage)
                            // 判断是不是最后一条数据 如果是最后一条数据 删除之后需要加载上一页数据
                            if ($('tbody tr').length > 1) {
                                // 如果长度大于一 就代表不是最后一条  正常加载数据
                                loadData(selpage)
                            } else {
                                loadData(selpage - 1)
                                // 如果长度为1 就加载上一页数据
                            }
                        }
                    }
                }
            )
        })
    })
</script>